// Arguments: Doubles, Doubles, Doubles
#include <stan/math/prim.hpp>

using stan::math::var;
using std::numeric_limits;
using std::vector;

class AgradCdfLogUniform : public AgradCdfLogTest {
 public:
  void valid_values(vector<vector<double> >& parameters,
                    vector<double>& cdf_log) {
    vector<double> param(3);

    param[0] = 0.1;   // y
    param[1] = -0.1;  // alpha
    param[2] = 5.0;   // beta
    parameters.push_back(param);
    cdf_log.push_back(std::log(0.2 / 5.1));  // expected cdf_log

    param[0] = 0.2;    // y
    param[1] = -0.25;  // alpha
    param[2] = 5.0;    // beta
    parameters.push_back(param);
    cdf_log.push_back(std::log(0.45 / 5.25));  // expected cdf_log

    param[0] = 0.05;  // y
    param[1] = -5;    // alpha
    param[2] = 5;     // beta
    parameters.push_back(param);
    cdf_log.push_back(std::log(5.05 / 10.0));  // expected cdf_log
  }

  void invalid_values(vector<size_t>& /*index*/, vector<double>& /*value*/) {
    // y

    // alpha

    // beta
  }

  bool has_lower_bound() { return false; }

  // BOUND INCLUDED IN ORDER FOR TEST TO PASS WITH CURRENT FRAMEWORK
  bool has_upper_bound() { return true; }

  double upper_bound() { return 5.0; }

  template <class T_y, class T_low, class T_high, typename T3, typename T4,
            typename T5>
  stan::return_type_t<T_y, T_low, T_high> cdf_log(const T_y& y,
                                                  const T_low& alpha,
                                                  const T_high& beta, const T3&,
                                                  const T4&, const T5&) {
    return stan::math::uniform_cdf_log(y, alpha, beta);
  }

  template <class T_y, class T_low, class T_high, typename T3, typename T4,
            typename T5>
  stan::return_type_t<T_y, T_low, T_high> cdf_log_function(const T_y& y,
                                                           const T_low& alpha,
                                                           const T_high& beta,
                                                           const T3&, const T4&,
                                                           const T5&) {
    using stan::math::include_summand;
    using stan::math::LOG_ZERO;

    if (y < alpha || y > beta)
      return LOG_ZERO;

    return log((y - alpha) / (beta - alpha));
  }
};
